

Gowin User Flash

ユーザーガイド

UG295-1.4.4J, 2024-09-27

#### 著作権について(2024)

著作権に関する全ての権利は、Guangdong Gowin Semiconductor Corporation に留保されています。

GO♥IN高云、Gowin、及びLittleBeeは、当社により、中国、米国特許商標庁、及びその他の国において登録されています。商標又はサービスマークとして特定されたその他全ての文字やロゴは、それぞれの権利者に帰属しています。何れの団体及び個人も、当社の書面による許可を得ず、本文書の内容の一部もしくは全部を、いかなる視聴覚的、電子的、機械的、複写、録音等の手段によりもしくは形式により、伝搬又は複製をしてはなりません。

#### 免責事項

当社は、GOWINSEMI Terms and Conditions of Sale (GOWINSEMI取引条件) に規定されている内容を除き、(明示的か又は黙示的かに拘わらず) いかなる保証もせず、また、知的財産権や材料の使用によりあなたのハードウェア、ソフトウェア、データ、又は財産が被った損害についても責任を負いません。当社は、事前の通知なく、いつでも本文書の内容を変更することができます。本文書を参照する何れの団体及び個人も、最新の文書やエラッタ(不具合情報) については、当社に問い合わせる必要があります。

# バージョン履歴

| 日付         | バージョン  | 説明                                                                                                                                                                 |
|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2020/08/24 | 1.0J   | 初版。                                                                                                                                                                |
| 2021/01/12 | 1.1J   | FLASH256KA の説明を追加。                                                                                                                                                 |
| 2021/07/14 | 1.2J   | <ul> <li>デバイス GW1N-2B、GW1N-1P5、GW1N-1P5B、GW1NR-2B の<br/>サポートを追加。</li> <li>IP 呼び出しの図面を更新。</li> <li>FLASH256KA を FLASH96KA に変更。</li> <li>FLASH96K の説明を更新。</li> </ul> |
| 2021/11/14 | 1.3J   | <ul><li>サポートされるデバイスを更新。</li><li>クロック周波数の説明を更新。</li><li>一部の説明を更新。</li></ul>                                                                                         |
| 2022/11/04 | 1.4J   | デバイス(GW1NS-2、GW1NS-2C、GW1NSE-2C、GW1NSR-2、GW1NSR-2C)を削除。                                                                                                            |
| 2023/01/05 | 1.4.1J | IP 呼び出しの一部の図面を更新、Device Version オプションを追加。                                                                                                                          |
| 2023/02/03 | 1.4.2J | ● Flash の特性のクロック周波数をアクセス時間に変更。<br>● タイミングパラメータの説明を更新。                                                                                                              |
| 2023/02/22 | 1.4.3J | FLASH64K、FLASH256K、FLASH96KA、FLASH608K のタイミングパラメータおよびタイミング図の説明を更新。                                                                                                 |
| 2024/09/27 | 1.4.4J | 「表 3-1 サポートされるデバイス」を更新。                                                                                                                                            |

# 目次

| 目次                     | i  |
|------------------------|----|
| 図一覧                    |    |
| 表一覧                    |    |
| 1 本マニュアルについて           |    |
| 1.1 マニュアルの内容           |    |
| 1.1 マーユノルの内容           |    |
| 1.3 用語、略語              |    |
| 1.4 テクニカル・サポートとフィードバック |    |
| 2 概要                   | 2  |
| 3 プリミティブの紹介            | 3  |
| 3.1 FLASH96K           | 3  |
| 3.2 FLASH64KZ          | 11 |
| 3.3 FLASH64K           | 17 |
| 3.4 FLASH256K          | 21 |
| 3.5 FLASH96KA          | 24 |
| 3.6 FLASH608K          | 28 |
| <b>4 IP</b> の呼が出し      | 32 |

# 図一覧

| 図 3-1 FLASH96K のポート図             | 4  |
|----------------------------------|----|
| 図 3-2 FLASH96K の読み出しモード          | 10 |
| 図 3-3 FLASH96K のページラッチ書き込みモード    | 10 |
| 図 3-4 FLASH96K のページラッチ・クリア・モード   | 10 |
| 図 3-5 FLASH96K の High レベル時間      | 11 |
| 図 3-6 FLASH64KZ のポート図            | 12 |
| 図 3-7 FLASH64KZ の読み出しタイミング       | 16 |
| 図 3-8 FLASH64KZ の書き込みタイミング       | 16 |
| 図 3-9 FLASH64KZ の消去タイミング         | 16 |
| 図 3-10 FLASH64K のポート図            | 17 |
| 図 3-11 FLASH256K のポート図           | 22 |
| 図 3-12 FLASH96KA のポート図           | 25 |
| 図 3-13 FLASH608K のポート図           | 29 |
| 図 <b>4-1 User Flash</b> の構成ウィンドウ | 33 |

# 表一覧

| 表 1-1 用語、略語                      | . 1  |
|----------------------------------|------|
| 表 <b>3-1</b> サポートされるデバイス         | . 3  |
| 表 3-2 FLASH96K のポートの説明           | 4    |
| 表 3-3 FLASH96K 出力データ幅の選択         | . 5  |
| 表 3-4 FLASH96K 入力データ幅の選択         | . 5  |
| 表 3-5 FLASH96K 操作モードの選択          | . 5  |
| 表 3-6 FLASH96K のタイミングパラメータ       | 9    |
| 表 3-7 FLASH64KZ のポートの説明          | . 12 |
| 表 3-8 FLASH64KZ のユーザーモードの真理値表    | . 13 |
| 表 3-9 FLASH64KZ のタイミングパラメータ      | . 14 |
| 表 3-10 FLASH64K のポートの説明          | . 17 |
| 表 3-11 FLASH64K のユーザーモードの真理値表    | . 18 |
| 表 3-12 FLASH256K のポートの説明         | . 22 |
| 表 3-13 FLASH256K のユーザーモードの真理値表   | . 23 |
| 表 3-14 FLASH96KA のポートの説明         | . 25 |
| 表 3-15 FLASH96KA のユーザーモードの真理値表   | . 26 |
| 表 3-16 FLASH608K のポートの説明         | . 29 |
| 表 3 17 FL A SH608K のユーザーチードの直理値表 | 20   |

UG295-1.4.4J iii

1本マニュアルについて 1.1マニュアルの内容

# 1本マニュアルについて

# 1.1 マニュアルの内容

本マニュアルでは、User Flash の機能、プリミティブの定義、およびその使用法について説明します。

# 1.2 関連ドキュメント

GOWIN セミコンダクターのホームページ <u>www.gowinsemi.com/ja</u>から、以下の関連ドキュメントがダウンロード、参考できます: Gowin Flash Controller IP ユーザーガイド(<u>IPUG901</u>)。

# 1.3 用語、略語

本マニュアルで使用される用語、略語、及びその意味を表 **1-1** に示します。

表 1-1 用語、略語

| 用語、略語   | 正式名称                          | 意味                        |  |
|---------|-------------------------------|---------------------------|--|
| FPGA    | Field Programmable Gate Array | フィールド・プログラマブ<br>ル・ゲート・アレイ |  |
| IP Core | Intellectual Property Core    | 設計資産コア                    |  |

# 1.4 テクニカル・サポートとフィードバック

GOWIN セミコンダクターは、包括的な技術サポートをご提供しています。使用に関するご質問、ご意見については、直接弊社までお問い合わせください。

ホームページ: www.gowinsemi.com/ja

E-mail: support@gowinsemi.com

UG295-1.4.4J 1(34)

# **2**概要

Gowin LittleBee ファミリーFPGA 製品は、User Flash を提供します。サポートされる User Flash の容量は、FPGA デバイスによって異なります。FLASH96K、FLASH64K、FLASH64KZ、FLASH256K、FLASH96KA、FLASH608K などがあります。

UG295-1.4.4J 2(34)

# **3**プリミティブの紹介

User Flash プリミティブとサポートされるデバイスの対応関係を表 3-1 に示します。

#### 表 3-1 サポートされるデバイス

| プリミティブ    | サポートされるデバイス                                                                                               |
|-----------|-----------------------------------------------------------------------------------------------------------|
| FLASH96K  | GW1N-1、GW1N-1S、GW1NR-1                                                                                    |
| FLASH64KZ | GW1NZ-LV1                                                                                                 |
| FLASH64K  | GW1NZ-ZV1、GW1NZ-1C                                                                                        |
| FLASH256K | GW1N-4、GW1N-4B、GW1N-4D、GW1NR-4、GW1NR-4B、GW1NR-4D、GW1NRF-4B、GW1NS-4、GW1NS-4C、GW1NSR-4、GW1NSR-4C、GW1NSER-4C |
| FLASH96KA | GW1N-2、GW1N-2B、GW1N-2C、GW1N-1P5、GW1N-1P5B、GW1N-1P5C、GW1NR-2、GW1NR-2B、GW1NR-2C、GW1NZ-2B、GW1NZ-2C           |
| FLASH608K | GW1N-9、GW1N-9C、GW1NR-9C                                                                                   |

#### 注記:

GW1NS-4C、GW1NSR-4C、GW1NSER-4Cの User Flash は MCU 専用です。

# **3.1 FLASH96K**

#### プリミティブの紹介

FLASH96K(96K ビット User Flash)の記憶領域は 96K ビットです。 この Flash の幅と深さは構成できません。幅が 4 バイト(32 ビット)、アドレス深さが 3K の不揮発性メモリです。初期値機能はサポートされていません。

FLASH96Kには以下の特徴があります。

- 100,000 回の書き込みサイクル
- 10 年以上のデータ保持時間(+85℃)
- 構成可能なデータ幅:8/16/32 ビット
- 容量:48 行\*64 列\*32 ビット = 96 K ビット

UG295-1.4.4J 3(34)

- ページサイズ:256 バイト
- **3**  $\mu$  **A** のスタンバイ電流
- ページ書き込み時間:8.2ms

#### ポート図

#### 図 3-1 FLASH96K のポート図



#### ポートの説明

表 3-2 FLASH96K のポートの説明

| ポート        | I/O | 説明                              |
|------------|-----|---------------------------------|
| DOUT[31:0] | 出力  | データ出力バス                         |
| DIN[31:0]  | 入力  | データ入力バス                         |
| RA[5:0]    | 入力  | メモリの行を選択するために使用される行アドレスバス。      |
| CA[5:0]    | 入力  | メモリの列を選択するために使用される列アドレスバス。      |
| PA[5:0]    | 入力  | ページラッチアドレスの列を選択するために使<br>用されます。 |
| MODE[3:0]  | 入力  | 操作モード                           |
| SEQ[1:0]   | 入力  | 操作の順序の制御。                       |
| ACLK       | 入力  | 読み出しと書き込みの同期クロック                |
| PW         | 入力  | ページラッチ・データのクロック入力。              |
| RESET      | 入力  | リセット信号、アクティブ High。              |
| PE         | 入力  | チャージポンプイネーブル                    |
| OE         | 入力  | データ出力イネーブル                      |
| RMODE[1:0] | 入力  | 読み出しデータ幅の制御                     |
| WMODE[1:0] | 入力  | 書き込みデータ幅の制御                     |

UG295-1.4.4J 4(34)

| ポート           | I/O | 説明            |
|---------------|-----|---------------|
| RBYTESEL[1:0] | 入力  | 読み出しデータのバイト選択 |
| WBYTESEL[1:0] | 入力  | 書き込みデータのバイト選択 |

#### 構成モード

ユーザーは、読み出し/書き込みモードおよび読み出し/書き込みバイト選択信号を使用して、入力および出力データの幅を変更できます。データの幅と制御信号の対応関係を表 3-3 および表 3-4 に示します。

#### 表 3-3 FLASH96K 出力データ幅の選択

| RMOD[1:0] | RBYTESEL |     | DOUT    |         |        |       |  |
|-----------|----------|-----|---------|---------|--------|-------|--|
| KWOD[1.0] | [1]      | [0] | [31:24] | [23:16] | [15:8] | [7:0] |  |
| 00        | Yes      | Yes | No      | No      | No     | Yes   |  |
| 01        | Yes      | No  | No      | No      | Yes    | Yes   |  |
| 1X        | No       | No  | Yes     | Yes     | Yes    | Yes   |  |

#### 表 3-4 FLASH96K 入力データ幅の選択

| WWOD[1:0] | WBYTESEL |     | DIN     |         |        |       |  |
|-----------|----------|-----|---------|---------|--------|-------|--|
| WMOD[1:0] | [1]      | [0] | [31:24] | [23:16] | [15:8] | [7:0] |  |
| 00        | Yes      | Yes | No      | No      | No     | Yes   |  |
| 01        | Yes      | No  | No      | No      | Yes    | Yes   |  |
| 1X        | No       | No  | Yes     | Yes     | Yes    | Yes   |  |

#### 注記:

「Yes」は有効であることを表し、「No」は無効であることを表します。

#### 動作モード

ユーザーは、MODE[3:0]の値を設定して操作モードを選択することができます。詳しくは表 3-5 に示す通りです。

#### 表 3-5 FLASH96K 操作モードの選択

| MODE[3:0] | 説明                             |
|-----------|--------------------------------|
| 0000      | 通常読み出し及びページラッチ・データ書き込み         |
| 0001      | プレグラミング・ビットをセット。書き込み開始後自動的にクリア |
| 0100      | ページラッチ・データをクリア                 |
| 1000      | ページ(または行)を消去                   |
| 1100      | ページ(または行)書き込み                  |

#### ● 読み出し

MODE を「0000」に設定した後、ACLK の立ち上がりエッジで読み

UG295-1.4.4J 5(34)

出しモードに入ります。読み出しモードでは、SEQ[1:0]の値を「00」の ままにする必要があります。データ取得時間の条件(<=38ns)が満たされた 後、データは出力ピン DOUT に現れます。

#### ● 書き込み

User Flash の書き込みは、5 つのステップで構成されます:

- 1. ページラッチ・データをクリア
- 2. データをページラッチに書き込む。
- 3. 選択したメモリユニットを仮想の「1」にプレプログラム。
- 4. 選択したメモリユニットを消去。
- 5. ページラッチ内のデータをメモリユニットに書き込む。

メモリユニットを消去した後、データは「0」になります。メモリユニットに書き込んだ後は、データは「1」になります。メモリユニットの「0」は、書き込みによって「1」になれますが、「1」は書き込みによって「0」になることができません。そのため、書き込み前に、メモリユニットを消去する必要があります。

#### ● ページラッチに書き込む

ページラッチは、Flash に書き込まれるデータをバッファリングする SRAM のようなものです。ページラッチへの書き込み操作は、PW 信号によってのみ制御され、ACLK とは関係ありません。PA(Page Address)信号は、書き込まれるページラッチのアドレスを指定します。

ページラッチへの書き込みの前に、まずデータを消去する必要があります。ページラッチにデータを 1 つずつ書き込み、MODE 値を「0000」、SEQ [1:0]を「00」に設定します。ページラッチへの書き込みとデータの読み出しは完全に独立しています。

#### ● ページラッチをクリア

ページラッチへの書き込みと違って、ページラッチのクリアは ACLK によって制御されます。MODE を「0100」に設定した後、ACLK の立ち上がりエッジの際ページラッチ・クリア・モードに入ります。このモードでは、SEQ[1:0]を「00」のままにする必要があります。ページラッチ・データは 1 つの ACLK サイクル内でクリアされます。

#### ● 消去および書き込み

消去および書き込み操作では、SEQ の値を順番に 1>2>3>0 に設定する必要があり、これらの操作にはミリ秒レベルの時間が必要です。消去後に同じページに 2 回書き込むことは禁止されています。

消去および書き込み操作前は、選択したメモリユニットにプレプログラミング操作によって仮想の「1」を書き込む必要があります。プレプログラミングの操作手順は次のとおりです。

1. PEP(pre-program)ビットをセットします(MODE=「0001」)。

UG295-1.4.4J 6(34)

2. High レベルの間に選択したエリアに書き込みます(MODE= 1100)。このプロセスは 100 マイクロ秒以上続きます。

その中で、MODE の値を「1100」に設定した後の手順は、消去および書き込み操作と同じく SEQ 1-> 2-> 3-> 0 を実行する必要がありますが、一部のタイミングが異なります(図 3-5)。例えば、Tpe が異なります(表 3-6)。

#### プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、4 IP の呼び出しを参照してください。

#### Verilog でのインスタンス化:

```
FLASH96K flash96k_inst(
      .RA(ra[5:0]),
      .CA(ca[5:0]),
      .PA(pa[5:0]),
      .MODE(mode[3:0]),
      .SEQ(seq[1:0]),
      .ACLK(aclk),
      .PW(pw),
      .RESET(reset),
      .PE(pe),
      .OE(oe),
      .RMODE(rmode[1:0]),
      .WMODE(wmode[1:0]),
      .RBYTESEL(rbytesel[1:0]),
      .WBYTESEL(wbytesel[1:0]),
      .DIN(din[31:0]),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH96K
        PORT(
            RA:IN std logic vector(5 downto 0);
            CA:IN std logic vector(5 downto 0);
            PA:IN std logic vector(5 downto 0);
            MODE: IN std logic vector(3 downto 0);
```

UG295-1.4.4J 7(34)

```
SEQ:IN std logic vector(1 downto 0);
          ACLK: IN std logic;
          PW:IN std_logic;
          RESET: IN std logic;
          PE:IN std logic;
          OE:IN std logic;
          RMODE:IN std_logic_vector(1 downto 0);
          WMODE: IN std_logic_vector(1 downto 0);
          RBYTESEL:IN std logic vector(1 downto 0);
          WBYTESEL:IN std_logic_vector(1 downto 0);
          DIN:IN std logic vector(31 downto 0);
          DOUT:OUT std logic vector(31 downto 0)
      );
END COMPONENT;
uut: FLASH96K
    PORT MAP (
          RA=>ra,
          CA=>ca,
          PA=>pa,
          MODE=>mode,
          SEQ=>seq.
          RESET=>reset.
          ACLK=>aclk,
          PW=>pw,
          PE=>pe,
          OE=>oe.
          RMODE=>rmode,
          WMODE=>wmode,
          RBYTESEL=>rbytesel,
          WBYTESEL=> wbytesel,
          DIN=>din.
          DOUT=>dout
   );
```

UG295-1.4.4J 8(34)

# タイミングパラメータ

# 表 3-6 FLASH96K のタイミングパラメータ

| パラメー | <b>⇒</b> ₩ <b>пп</b>            | 仕様  | 出任  |     |            |
|------|---------------------------------|-----|-----|-----|------------|
| タ    | 説明                              | 最小値 | 標準値 | 最大値 | 単位         |
| Taa  | データ取得時間                         | -   | _   | 38  | ns         |
| Тсу  | 読み出しサイクル                        | 43  | _   | -   | ns         |
| Taw  | ACLK の High レベル時間               | 10  | -   | -   | ns         |
| Tawl | ACLK の Low レベル時間                | 10  | -   | -   | ns         |
| Tas  | セットアップ時間                        | 3   | -   | -   | ns         |
| Tah  | ホールド時間                          | 3   | _   | -   | ns         |
| Toz  | OE プルダウンから高イン<br>ピーダンスの時間       | -   | -   | 2   | ns         |
| Toe  | OE プルアップからデータ<br>出力の時間          | -   | _   | 2   | ns         |
| Twcy | 書き込みサイクル                        | 40  | _   | =   | ns         |
| Tpw  | PW の High レベル時間                 | 16  | _   | -   | ns         |
| Tpwl | PW の Low レベル時間                  | 16  | -   | -   | ns         |
| Tpas | ページアドレスのセットア<br>ップ時間            | 3   | _   | _   | ns         |
| Tpah | ページアドレスのホールド<br>時間              | 3   | _   | _   | ns         |
| Tds  | データのセットアップ時間                    | 16  | -   | -   | ns         |
| Tdh  | データのホールド時間                      | 3   | -   | -   | ns         |
| Ts0  | SEQ=0 の場合のサイクル                  | 6   | _   | _   | $\mu$ s    |
| Ts1  | SEQ=1の場合のサイクル                   | 15  | _   | -   | $\mu$ s    |
| Ts2p | ACLKからPE立ち上がりエ<br>ッジのセットアップ時間   | 5   | _   | 10  | $\mu$ S    |
| Ts3  | SEQ=3の場合のサイクル                   | 5   | -   | 10  | $\mu$ s    |
| Tps3 | PE 立ち下がりエッジから<br>ACLK のセットアップ時間 | 60  | _   |     | μ <b>s</b> |
|      | MODE=1000 の場合、消去<br>時間          | 5.7 | 6   | 6.3 | ms         |
| Тре  | MODE=1100 の場合、書き込<br>み時間        | 1.9 | 2   | 2.1 | ms         |
|      | MODE=11xx の場合、プレプログラミング時間       | 190 | 200 | 210 | μs         |

UG295-1.4.4J 9(34)

#### タイミング図

#### 図 3-2 FLASH96K の読み出しモード



#### 注記:

読み出しモードの場合、SEQ=0。ADDR 信号にはRA、CA、RMOD、RBYTESEL が含まれます。

図 3-3 FLASH96K のページラッチ書き込みモード



#### 注記:

ページラッチ書き込みモードの場合、SEQ=0、MODE=0000です。

図 3-4 FLASH96K のページラッチ・クリア・モード



#### 注記:

プレプログラミング・ビットのセットのタイミングと、データをすべてのページに書き 込むタイミングと、ページラッチ・クリアのタイミングのパラメータは同じで、MODE 値だけが異なります。

UG295-1.4.4J 10(34)



# 3.2 FLASH64KZ

#### プリミティブの紹介

FLASH64KZ(64K ビット User Flash)の記憶領域は 64K ビットです。 この Flash の幅と深さは構成できません。不揮発性メモリです。初期値機 能はサポートされていません。

FLASH64KZには以下の特徴があります。

- 10,000 回の書き込みサイクル
- 容量:32 行\*64 列\*32 ビット = 64 K ビット
- 10年以上のデータ保持時間(+85℃)
- ページ消去をサポート: 2,048 バイト
- 高速なページ消去/書き込み
- アクセス時間:最大 **25ns**
- プログラミング時間:最大 16 μ s
- ページ消去時間:最大 120ms
- 電流
  - 読み出し: 2.19mA/25ns (Vcc) & 0.5mA/25ns (Vccx)(MAX)
  - 書き込み/消去:12/12mA(Max)

UG295-1.4.4J 11(34)

#### ポート図

#### 図 3-6 FLASH64KZ のポート図



#### ポートの説明

#### 表 3-7 FLASH64KZ のポートの説明

| ポート        | I/O | 説明                                              |
|------------|-----|-------------------------------------------------|
| DOUT[31:0] | 出力  | データ出力バス                                         |
| DIN[31:0]  | 入力  | データ入力バス                                         |
| XADR[4:0]  | 入力  | ページ内の特定の行を選択するために使用される X アドレスバス。                |
| YADR[5:0]  | 入力  | 行内の特定の列の選択に使用される Y アドレスバス。                      |
| XE         | 入力  | X アドレスイネーブル信号。XE が 0 の場合、すべての<br>行アドレスが無効になります。 |
| YE         | 入力  | Y アドレスイネーブル信号。YE が 0 の場合、すべての<br>列アドレスが無効になります。 |
| SE         | 入力  | センスアンプイネーブル信号、アクティブ High。                       |
| ERASE      | 入力  | 消去信号、アクティブ High。                                |
| PROG       | 入力  | 書き込み信号、アクティブ High。                              |
| NVSTR      | 入力  | Flash データストレージ信号、アクティブ High。                    |

#### 構成モード

GW1NZ シリーズ FPGA 製品の User Flash は、汎用モードと低消費電力モードがあります。FLASH64KZ は汎用モードの User Flash です。

FLASH64KZ はデフォルトでオンになっており、電源を投入した後、消去/読み出しと書き込みなどの通常の操作を実行できます。オフ状態への切り替えはサポートされていません。

UG295-1.4.4J 12(34)

#### 動作モード

表 3-8 FLASH64KZ のユーザーモードの真理値表

| モード          | XE | YE | SE | PROG | ERASE | NVSTR |
|--------------|----|----|----|------|-------|-------|
| 読み出しモード      | Н  | Н  | Н  | L    | L     | L     |
| 書き込みモード      | Н  | Н  | L  | Н    | L     | Н     |
| ページ消去モ<br>ード | Н  | L  | L  | L    | Н     | Н     |

#### 注記:

「H」と「L」は、それぞれ High レベルと Low レベルを示します。

#### プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、4 IP の呼び出しを参照してください。

## Verilog でのインスタンス化:

```
FLASH64KZ flash64kz inst(
      .XADR(xadr[4:0]),
      .YADR(yadr[5:0]),
      .XE(xe),
      .YE(ye),
      .SE(se),
      .ERASE(erase),
      .PROG(prog),
      .NVSTR(nvstr),
      .DIN(din[31:0]),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH64KZ
       PORT(
            XADR:IN std logic vector(4 downto 0);
            YADR:IN std_logic_vector(5 downto 0);
            XE:IN std logic;
            YE:IN std_logic;
            SE:IN std_logic;
            ERASE: IN std logic;
```

UG295-1.4.4J 13(34)

```
PROG: IN std logic;
         NVSTR:IN std_logic;
         DIN:IN std_logic_vector(31 downto 0);
         DOUT:OUT std_logic_vector(31 downto 0)
     );
END COMPONENT;
uut: FLASH64KZ
    PORT MAP (
         XADR=>xadr,
         YADR=>yadr,
         XE=>xe,
         YE=>ye,
          SE=>se,
         ERASE=>erase,
         PROG=>prog,
         NVSTR=>nvstr,
         DIN=>din,
          DOUT=>dout
   );
```

表 3-9 FLASH64KZ のタイミングパラメータ

タイミングパラメータ[1][5][6]

| ユーザーモード                     | パラメータ      | 記号                              | 最小値 | 最大値 | 単位         |
|-----------------------------|------------|---------------------------------|-----|-----|------------|
|                             | WC1        |                                 | -   | 25  | ns         |
|                             | TC         |                                 | -   | 22  | ns         |
| アクセス時<br>間[2]               | BC         | T <sub>acc</sub> <sup>[3]</sup> | -   | 21  | ns         |
| IHJ                         | LT         |                                 | -   | 21  | ns         |
|                             | WC         |                                 | -   | 25  | ns         |
| 書き込み/消去<br>トアップ時間           | からデータ保存のセッ | T <sub>nvs</sub>                | 5   | -   | μs         |
| データ保存のス                     | トールド時間     | T <sub>nvh</sub>                | 5   | -   | $\mu$ s    |
| データ保存のホールド時間 <b>(</b> マス消去) |            | T <sub>nvh1</sub>               | 100 | -   | μ <b>S</b> |
| データ保存か<br>ップ時間              | ら書き込みのセットア | T <sub>pgs</sub>                | 10  | -   | μ <b>S</b> |
| プログラミング                     | グのホールド時間   | T <sub>pgh</sub>                | 20  | -   | ns         |
| プログラミング                     | グ時間        | T <sub>prog</sub>               | 8   | 16  | μ <b>S</b> |

UG295-1.4.4J 14(34)

| ユーザーモード                        | パラメータ     |         | 記号                  | 最小値 | 最大値 | 単位      |  |  |  |  |  |   |    |   |    |   |    |
|--------------------------------|-----------|---------|---------------------|-----|-----|---------|--|--|--|--|--|---|----|---|----|---|----|
| 書き込みの準備時                       | 書き込みの準備時間 |         |                     |     | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| 書き込みのホール                       | レド時       | 間       | T <sub>whd</sub>    | >0  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| 制御信号から書き ットアップ時間               | き込み       | /消去までのセ | T <sub>cps</sub>    | -10 | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| SE から読み出し<br>時間                | まで        | のセットアップ | Tas                 | 0.1 | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| SE パルスの High                   | 1 レベ      | い時間     | T <sub>pws</sub>    | 5   | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| アドレス/データの                      | のセッ       | トアップ時間  | T <sub>ads</sub>    | 20  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| アドレス/データの                      | のホー       | ルド時間    | T <sub>adh</sub>    | 20  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| データのホールト                       | 、時間       |         | T <sub>dh</sub>     | 0.5 | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
|                                |           | WC1     | T <sub>ah</sub>     | 25  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| 読み出しモードの                       | のア        | TC      | -                   | 22  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| ドレスのホール                        | ド時        | ВС      | -                   | 21  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| 間[3]                           |           |         |                     |     |     |         |  |  |  |  |  | L | LT | - | 21 | - | ns |
|                                |           | WC      | -                   | 25  | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| SE パルスの Low                    | レベ        | ル時間     | T <sub>nws</sub>    | 2   | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| リカバリー時間                        |           |         | Trcv                | 10  | -   | $\mu$ S |  |  |  |  |  |   |    |   |    |   |    |
| データ保持時間                        |           |         | T <sub>hv</sub> [4] | -   | 6   | ms      |  |  |  |  |  |   |    |   |    |   |    |
| 消去時間                           |           |         | T <sub>erase</sub>  | 100 | 120 | ms      |  |  |  |  |  |   |    |   |    |   |    |
| マス消去時間                         |           |         | T <sub>me</sub>     | 100 | 120 | ms      |  |  |  |  |  |   |    |   |    |   |    |
| パワーダウンから待機モードまでの<br>Wake-up 時間 |           |         | Twk_pd              | 7   | -   | μs      |  |  |  |  |  |   |    |   |    |   |    |
| 待機のホールド時                       | 持間        |         | T <sub>sbh</sub>    | 100 | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| Vccのセットアッ                      | プ時        | <br>間   | T <sub>ps</sub>     | 0   | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |
| Vccxのホールド                      | 時間        |         | T <sub>ph</sub>     | 0   | -   | ns      |  |  |  |  |  |   |    |   |    |   |    |

#### 注記:

- [1]これらの設定値は変更される場合があります。
- 「<sup>2</sup>これらの数値はシミュレーションデータに過ぎません。
- 「<sup>3]</sup>信号 XADR、YADR、XE、及び YE が有効になった後、Tacc の開始時間は SE 信号 の立ち上がりエッジになります。読み出されたデータ DOUT は、次の有効な読み出しまで保存されます。
- 「AlThy(Cumulative program high voltage period)は書き込みの開始から次のデータ消去までの累積時間です。次の消去前に同じアドレスに2回書き込むことはできません。次の消去前に同じメモリユニットに2回書き込むことはできません。このような制限は安全のためです。
- 「りすべての波形には、1ns の立ち上がりエッジ時間と 1ns の立ち下がりエッジ時間 があります。
- 「同制御信号 XADR、YADR、XE、及び YE は少なくとも Tacc ホールドする必要があり、Tacc は SE の立ち上がりエッジから開始します。

UG295-1.4.4J 15(34)

## タイミング図

#### 図 3-7 FLASH64KZ の読み出しタイミング



#### 図 3-8 FLASH64KZ の書き込みタイミング





UG295-1.4.4J 16(34)

# **3.3 FLASH64K**

#### プリミティブの紹介

FLASH64K(64K ビット User Flash)の記憶領域は 64K ビットです。 この Flash の幅と深さは構成できません。不揮発性メモリです。初期値機 能はサポートされていません。FLASH64K にはスリープモードがありま す。SLEEP 信号が High の場合、FLASH はスリープモードに入ります。

#### FLASH64K には以下の特徴があります:

- 10,000 回の書き込みサイクル
- 容量:32 行\*64 列\*32 ビット = 64 K ビット
- 10 年以上のデータ保持時間(+85℃)
- ページ消去をサポート: 2,048 バイト
- 高速なページ消去/書き込み
- アクセス時間:最大 **25ns**
- プログラミング時間:最大 16 μ s
- ページ消去時間:最大 120ms
- 電流
  - 読み出し: 2.19mA/25ns (Vcc) & 0.5mA/25ns (Vccx)(MAX)
  - 書き込み/消去:12/12mA(Max)

#### ポート図

#### 図 3-10 FLASH64K のポート図



#### ポートの説明

#### 表 3-10 FLASH64K のポートの説明

| ポート        | I/O | 説明       |
|------------|-----|----------|
| DOUT[31:0] | 出力  | データ出力バス。 |
| DIN[31:0]  | 入力  | データ入力バス  |

UG295-1.4.4J 17(34)

| ポート       | I/O | 説明                                                |
|-----------|-----|---------------------------------------------------|
| XADR[4:0] | 入力  | ページ内の特定の行を選択するために使用されるX<br>アドレスバス。                |
| YADR[5:0] | 入力  | 行内の特定の列の選択に使用される Y アドレスバス。                        |
| XE        | 入力  | X アドレスイネーブル信号。XE が 0 の場合、すべ<br>ての行アドレスが無効になります。   |
| YE        | 入力  | Y アドレスイネーブル信号。YE が 0 の場合、すべ<br>ての列アドレスが無効になります。   |
| SE        | 入力  | センスアンプイネーブル信号、アクティブ High。                         |
| ERASE     | 入力  | 消去信号、アクティブ High。                                  |
| PROG      | 入力  | 書き込み信号、アクティブ High。                                |
| NVSTR     | 入力  | Flash データストレージ信号、アクティブ High。                      |
| SLEEP     | 入力  | 低消費電力 User Flash 状態の切り替え信号。  ● High: オン  ● Low:オフ |

#### 構成モード

**GW1NZ** シリーズ FPGA 製品の User Flash は、汎用モードと低消費電力モードがあります。FLASH64K は低消費電力モードの User Flash です。

FLASH64K はデフォルトでオフになっており、消費電力を効果的に削減できます。SLEEP ピンを制御することでオン/オフを動的に切り替えることができます。オンに切り替えると、FLASH64KZ のように消去/読み出しと書き込みが可能です。

#### 動作モード

#### 表 3-11 FLASH64K のユーザーモードの真理値表

| モード          | XE | YE | SE | PROG | ERASE | NVSTR |
|--------------|----|----|----|------|-------|-------|
| 読み出しモード      | Н  | Н  | Н  | L    | L     | L     |
| 書き込みモード      | Н  | Н  | L  | Н    | L     | Н     |
| ページ消去モ<br>ード | Н  | L  | L  | L    | Н     | Н     |

#### 注記:

「H」と「L」は、それぞれ High レベルと Low レベルを示します。

#### プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、4 IP の呼び出しを参照してください。

#### Verilog でのインスタンス化:

FLASH64K flash64k\_inst(

UG295-1.4.4J 18(34)

```
.XADR(xadr[4:0]),
      .YADR(yadr[5:0]),
      .XE(xe),
      .YE(ye),
      .SE(se),
      .ERASE(erase),
      .PROG(prog),
      .NVSTR(nvstr),
      .DIN(din[31:0]),
      .SLEEP(sleep),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH64K
        PORT(
            XADR:IN std_logic_vector(4 downto 0);
            YADR:IN std_logic_vector(5 downto 0);
            XE:IN std logic;
            YE:IN std_logic;
            SE:IN std logic;
            ERASE:IN std_logic;
            PROG: IN std logic;
            NVSTR:IN std logic;
            DIN:IN std_logic_vector(31 downto 0);
            SLEEP: IN std_logic;
            DOUT:OUT std_logic_vector(31 downto 0)
        );
  END COMPONENT:
  uut: FLASH64K
       PORT MAP (
            XADR=>xadr,
            YADR=>yadr,
            XE=>xe,
            YE=>ye,
            SE=>se,
```

UG295-1.4.4J 19(34)

```
ERASE=>erase,
PROG=>prog,
NVSTR=>nvstr,
DIN=>din,
SLEEP=>sleep,
DOUT=>dout
);
```

### タイミングパラメータとタイミング図

FLASH64K のタイミングパラメータとタイミング図は FLASH64KZ と同様であるため、そのタイミングパラメータおよびタイミング図については、3.2 FLASH64KZ を参照してください。

UG295-1.4.4J 20(34)

**3**プリミティブの紹介 3.4 FLASH256K

# **3.4 FLASH256K**

プリミティブの紹介

FLASH256K(256K ビット User Flash)の記憶領域は 256K ビットです。この Flash の幅と深さは構成できません。不揮発性メモリです。初期 値機能はサポートされていません。

FLASH256K は、行メモリユニットと列メモリユニットで構成されています。1行メモリユニットは64 列メモリユニットで構成されています。1列メモリユニットの容量は32 ビットで、1行メモリユニットの容量は64\*32=2048 ビットです。ページ消去がサポートされており、1ページの容量は2048 バイトです。すなわち、1ページには8行があります。その特徴は以下に示す通りです:

- 10,000 回の書き込みサイクル
- 10 年以上のデータ保持時間(+85℃)
- データ幅: 32 ビット
- 容量: 128 行\*64 列\*32 ビット = 256 K ビット
- ページ消去をサポート: 2.048 バイト
- 高速ページ消去/書き込み/読み出し
- アクセス時間:最大 25ns
- プログラミング時間:最大 16 µ s
- ページ消去時間:最大 120ms
- 電流
  - 読み出し電流/継続時間:2.19mA/25ns (Vcc) & 0.5mA/25ns (Vccx)(MAX)
  - 書き込み/消去:12/12mA(Max)

UG295-1.4.4J 21(34)

**3** プリミティブの紹介 3.4 FLASH256K

ポート図

## 図 3-11 FLASH256K のポート図



# ポートの説明

#### 表 3-12 FLASH256K のポートの説明

| ポート        | I/O | 説明                                                                                                         |
|------------|-----|------------------------------------------------------------------------------------------------------------|
| DOUT[31:0] | 出力  | データ出力バス。                                                                                                   |
| DIN[31:0]  | 入力  | データ入力バス                                                                                                    |
| XADR[6:0]  | 入力  | X アドレスバス。XADR [n:3]は特定のページを選択するために使用されます。XADR [2:0]は1ページ内の特定の行を選択するために使用されます。1ページは8行で構成され、1行は64列で構成されています。 |
| YADR[5:0]  | 入力  | 行から特定の列を選択するために使用される Y ア<br>ドレスバス。1 行は 64 列で構成されています。                                                      |
| XE         | 入力  | X アドレスイネーブル信号。XE が 0 の場合、すべての行アドレスが無効になります。                                                                |
| YE         | 入力  | Y アドレスイネーブル信号。YE が 0 の場合、すべての列アドレスが無効になります。                                                                |
| SE         | 入力  | センスアンプイネーブル信号、アクティブ High。                                                                                  |
| PROG       | 入力  | 書き込み信号、アクティブ High。                                                                                         |
| ERASE      | 入力  | 消去信号、アクティブ High。                                                                                           |
| NVSTR      | 入力  | Flash データストレージ信号、アクティブ High。                                                                               |

UG295-1.4.4J 22(34)

**3**プリミティブの紹介 3.4 FLASH256K

#### 動作モード

表 3-13 FLASH256K のユーザーモードの真理値表

| モード          | XE | YE | SE | PROG | ERASE | NVSTR |
|--------------|----|----|----|------|-------|-------|
| 読み出しモード      | Н  | Н  | Н  | L    | L     | L     |
| 書き込みモード      | Н  | Н  | L  | Н    | L     | Н     |
| ページ消去モ<br>ード | Н  | L  | L  | L    | Н     | Н     |

#### 注記:

「H」と「L」は、それぞれ High レベルと Low レベルを示します。

#### プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、<u>4 IP の呼び出し</u>を参照してください。

## Verilog でのインスタンス化:

```
FLASH256K flash256k inst(
      .XADR(xadr[6:0]),
      .YADR(yadr[5:0]),
      .XE(xe),
      .YE(ye),
      .SE(se),
      .ERASE(erase),
      .PROG(prog),
      .NVSTR(nvstr),
      .DIN(din[31:0]),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH256K
       PORT(
             DIN:IN std logic vector(31 downto 0);
             XADR:IN std logic vector(6 downto 0);
             YADR:IN std logic vector(5 downto 0);
             XE:IN std_logic;
             YE:IN std_logic;
             SE:IN std logic;
```

UG295-1.4.4J 23(34)

```
ERASE: IN std logic;
          PROG: IN std logic;
          NVSTR: IN std logic;
          DOUT:OUT std logic vector(31 downto 0)
   );
END COMPONENT:
uut: FLASH256K
    PORT MAP (
          DIN=>din.
          XADR=>xadr,
          YADR=>yadr,
          XE=>xe.
          YE=>ye,
          SE=>se.
          ERASE=>erase,
          PROG=>prog,
          NVSTR=>nvstr,
          DOUT=>dout
   );
```

#### タイミングパラメータとタイミング図

FLASH256K のタイミングパラメータとタイミング図は FLASH64KZ と同様であるため、そのタイミングパラメータおよびタイミング図については、3.2 FLASH64KZ を参照してください。

# 3.5 FLASH96KA

プリミティブの紹介

FLASH96KA(96K ビット User Flash)の記憶領域は96K ビットです。

そのタイミングは FLASH256K と同様です。FLASH256K に比べて、スリープ機能が追加され、SLEEP 信号が High になると FLASH96KA はスリープモードに入ります。この Flash の幅と深さは構成できません。不揮発性メモリです。初期値機能はサポートされていません。

FLASH96KA は、行メモリユニットと列メモリユニットで構成されています。1行メモリユニットは64 列メモリユニットで構成されています。1 列メモリユニットの容量は32 ビットで、1 行メモリユニットの容量は64\*32=2048 ビットです。ページ消去がサポートされ、ページあたりの容量は2048 バイトです。すなわち、1 ページには8 行があります。そ

UG295-1.4.4J 24(34)

#### の特性は以下に示す通りです:

- 10,000 回の書き込みサイクル
- 10 年以上のデータ保持時間(+85℃)
- データ幅:32 ビット
- 容量:48 行\*64 列\*32 ビット = 96 K ビット
- ページ消去をサポート: 2.048 バイト
- 高速ページ消去/書き込み/読み出し
- アクセス時間:最大 **25ns**
- プログラミング時間:最大 16 μ s
- ページ消去時間:最大 120ms
- 電流
  - 読み出し電流/継続時間:2.19mA/25ns (Vcc) & 0.5mA/25ns (Vccx)(MAX)
  - 書き込み/消去:12/12mA(Max)

#### ポート図

#### 図 3-12 FLASH96KA のポート図



#### ポートの説明

#### 表 3-14 FLASH96KA のポートの説明

| ポート        | I/O | 説明       |
|------------|-----|----------|
| DOUT[31:0] | 出力  | データ出力バス。 |
| DIN[31:0]  | 入力  | データ入力バス  |

UG295-1.4.4J 25(34)

| ポート       | I/O | 説明                                                                                                        |
|-----------|-----|-----------------------------------------------------------------------------------------------------------|
| XADR[5:0] | 入力  | Xアドレスバス。XADR [n:3]は特定のページを選択するために使用されます。XADR [2:0]は1ページ内の特定の行を選択するために使用されます。1ページは8行で構成され、1行は64列で構成されています。 |
| YADR[5:0] | 入力  | 行から特定の列を選択するために使用される Y アドレスバス。1 行は 64 列で構成されています。                                                         |
| XE        | 入力  | X アドレスイネーブル信号。XE が 0 の場合、すべての行アドレスが無効になります。                                                               |
| YE        | 入力  | Y アドレスイネーブル信号。YE が 0 の場合、すべての列アドレスが無効になります。                                                               |
| SE        | 入力  | センスアンプイネーブル信号、アクティブ<br>High。                                                                              |
| PROG      | 入力  | 書き込み信号、アクティブ High。                                                                                        |
| ERASE     | 入力  | 消去信号、アクティブ High。                                                                                          |
| NVSTR     | 入力  | Flash データストレージ信号、アクティブ High。                                                                              |
| SLEEP     | 入力  | スリープ信号。アクティブ High。                                                                                        |

#### 動作モード

#### 表 3-15 FLASH96KA のユーザーモードの真理値表

| モード          | XE | YE | SE | PROG | ERASE | NVSTR |
|--------------|----|----|----|------|-------|-------|
| 読み出しモード      | Н  | Н  | Н  | L    | L     | L     |
| 書き込みモード      | Н  | Н  | L  | Н    | L     | Н     |
| ページ消去モ<br>ード | Н  | L  | L  | L    | Н     | Н     |

#### 注記:

「H」と「L」は、それぞれ High レベルと Low レベルを示します。

# プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、4 IP の呼び出しを参照してください。

## Verilog でのインスタンス化:

#### FLASH96KA FLASH96KA\_inst(

.XADR(xadr[5:0]),

.YADR(yadr[5:0]),

.XE(xe),

.YE(ye),

UG295-1.4.4J 26(34)

```
.SE(se),
      .ERASE(erase),
      .PROG(prog),
      .NVSTR(nvstr),
      .DIN(din[31:0]),
      .SLEEP(sleep),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH96KA
       PORT(
           DIN:IN std logic vector(31 downto 0);
           XADR:IN std logic vector(5 downto 0);
           YADR:IN std_logic_vector(5 downto 0);
           XE:IN std_logic;
           YE:IN std_logic;
           SE:IN std_logic;
           ERASE: IN std logic;
           PROG:IN std_logic;
           NVSTR:IN std logic;
           SLEEP: IN std_logic;
           DOUT:OUT std logic vector(31 downto 0)
      );
  END COMPONENT;
  uut: FLASH96KA
      PORT MAP (
           DIN=>din,
           XADR=>xadr,
           YADR=>yadr,
           XE=>xe,
           YE=>ye,
           SE=>se,
           ERASE=>erase,
           PROG=>prog,
            NVSTR=>nvstr,
```

UG295-1.4.4J 27(34)

# SLEEP=>sleep, DOUT=>dout

);

#### タイミングパラメータとタイミング図

FLASH96KA のタイミングパラメータとタイミング図は FLASH64KZ と同様であるため、そのタイミングパラメータおよびタイミング図については、3.2 FLASH64KZ を参照してください。

# 3.6 FLASH608K

#### プリミティブの紹介

FLASH608K(608K ビット User Flash)の記憶領域は 608K ビットです。この Flash の幅と深さは構成できません。不揮発性メモリです。初期 値機能はサポートされていません。

FLASH608K は、行メモリユニットと列メモリユニットで構成されています。1行メモリユニットは64 列メモリユニットで構成されています。1列メモリユニットの容量は32 ビットで、1行メモリユニットの容量は64\*32=2048 ビットです。ページ消去がサポートされ、ページあたりの容量は2048 バイトです。すなわち、1ページには8行があります。その特性は以下に示す通りです:

- 10.000 回の書き込みサイクル
- 10 年以上のデータ保持時間(+85℃)
- データ幅: 32 ビット
- 容量:304 行\*64 列\*32 ビット = 608 K ビット
- ページ消去をサポート: 2,048 バイト
- 高速ページ消去/書き込み/読み出し
- アクセス時間:最大 25ns
- プログラミング時間:最大 16 μ s
- ページ消去時間:最大 120ms
- 電流
  - 読み出し電流/継続時間:2.19mA/25ns (Vcc) & 0.5mA/25ns (Vccx)(MAX)
  - 書き込み/消去:12/12mA(Max)

UG295-1.4.4J 28(34)

#### ポート図

## 図 3-13 FLASH608K のポート図



# ポートの説明

#### 表 3-16 FLASH608K のポートの説明

| ポート        | I/O | 説明                                                                                                                        |
|------------|-----|---------------------------------------------------------------------------------------------------------------------------|
| DOUT[31:0] | 出力  | データ出力バス。                                                                                                                  |
| DIN[31:0]  | 入力  | データ入力バス                                                                                                                   |
| XADR[8:0]  | 入力  | Xアドレスバス。XADR [n:3]は特定のページを<br>選択するために使用されます。XADR [2:0]は1<br>ページ内の特定の行を選択するために使用されま<br>す。1ページは8行で構成され、1行は64列で<br>構成されています。 |
| YADR[5:0]  | 入力  | 行から特定の列を選択するために使用される Y アドレスバス。1 行は 64 列で構成されています。                                                                         |
| XE         | 入力  | X アドレスイネーブル信号。XE が 0 の場合、す<br>べての行アドレスが無効になります。                                                                           |
| YE         | 入力  | Y アドレスイネーブル信号。YE が 0 の場合、すべての列アドレスが無効になります。                                                                               |
| SE         | 入力  | センスアンプイネーブル信号、アクティブ<br>High。                                                                                              |
| PROG       | 入力  | 書き込み信号、アクティブ High。                                                                                                        |
| ERASE      | 入力  | 消去信号、アクティブ High。                                                                                                          |
| NVSTR      | 入力  | Flash データストレージ信号、アクティブ High。                                                                                              |

# 動作モード

#### 表 3-17 FLASH608K のユーザーモードの真理値表

| モード     | XE | YE | SE | PROG | ERASE | NVSTR |
|---------|----|----|----|------|-------|-------|
| 読み出しモード | н  | Н  | Н  | L    | L     | L     |

UG295-1.4.4J 29(34)

| モード          | XE | YE | SE | PROG | ERASE | NVSTR |
|--------------|----|----|----|------|-------|-------|
| 書き込みモード      | Н  | Н  | L  | Н    | L     | Н     |
| ページ消去モ<br>ード | Н  | L  | L  | L    | Н     | Н     |

#### 注記:

「H」と「L」は、それぞれ High レベルと Low レベルを示します。

#### プリミティブのインスタンス化

プリミティブを直接インスタンス化するか、IP Core Generator で生成できます。詳しくは、4 IP の呼び出しを参照してください。

### Verilog でのインスタンス化:

```
FLASH608K flash608k inst(
      .XADR(xadr[8:0]),
      .YADR(yadr[5:0]),
      .XE(xe),
      .YE(ye),
      .SE(se),
      .ERASE(erase),
      .PROG(prog),
      .NVSTR(nvstr),
      .DIN(din[31:0]),
      .DOUT(dout[31:0])
  );
VHDL でのインスタンス化:
  COMPONENT FLASH608K
        PORT(
            DIN:IN std_logic_vector(31 downto 0);
            XADR:IN std logic vector(8 downto 0);
            YADR:IN std logic vector(5 downto 0);
            XE:IN std_logic;
            YE: IN std logic;
            SE:IN std_logic;
            ERASE: IN std logic;
            PROG: IN std logic;
            NVSTR:IN std_logic;
            DOUT:OUT std logic vector(31 downto 0)
```

UG295-1.4.4J 30(34)

```
);
END COMPONENT;
uut: FLASH608K
PORT MAP (
DIN=>din,
XADR=>xadr,
YADR=>yadr,
XE=>xe,
YE=>ye,
SE=>se,
ERASE=>erase,
PROG=>prog,
NVSTR=>nvstr,
DOUT=>dout
);
```

#### タイミングパラメータとタイミング図

FLASH608K のタイミングパラメータとタイミング図は FLASH64KZ と同様であるため、そのタイミングパラメータおよびタイミング図については、3.2 FLASH64KZ を参照してください。

UG295-1.4.4J 31(34)

# **4**IP の呼び出し

IP Core Generator はハードコアの User Flash とソフトコアの Gowin Flash Controller IP の生成をサポートします。Gowin Flash Controller IP の機能および GUI での呼び出しについては、『Gowin Flash Controller IP ユーザーガイド(<u>IPUG901</u>)』を参照してください。IP Core Generator > Hard Module > User Flash を選択して User Flash ハードコア IP を構成してください。

IP Core Generator の画面で「User Flash」をクリックすると右側に User Flash の概要が表示されます。

#### IP の構成

IP Core Generator 画面で「User Flash」をダブルクリックすると、User Flash の「IP Customization」ウィンドウがポップアップします。このウィンドウには「General」構成ボックスとポート図があります(図 4-1)。

UG295-1.4.4J 32(34)



#### 図 4-1 User Flash の構成ウィンドウ

- 1. 「General」構成ボックス: IPファイルの構成に使用されます。
  - Device:対象デバイス。
  - Device Version:デバイスのバージョン。
  - Part Number:部品番号。
  - Language: IP を実現するハードウェア記述言語。右側のドロップダウン・リストからターゲット言語(Verilog または VHDL)を選択します。
  - Module Name: 生成される IP ファイルのモジュール名。右側の テキストボックスで編集できます。 Module Name をプリミティブ 名と同じにすることはできません。同じである場合、エラーが報 告されます。
  - File Name: 生成される IP ファイルのファイル名。右側のテキストボックスで再編集できます。
  - Create In: 生成される IP ファイルのパス。右側のテキストボックスでパスを直接編集するか、テキストボックスの右側にある選択ボタンを使用してパスを選択できます。
- 2. ポート図: User Flash のポート図はデバイスによって異なります(図 4-1)。

UG295-1.4.4J 33(34)

#### 生成されるファイル

IP の構成が完了すると、「File Name」によって命名された3つのファイルが生成されます:

- 「gowin\_user\_flash.v」は完全な verilog モジュールです。
- 「gowin user flash tmp.v」は IP のテンプレートファイルです。
- 「gowin\_user\_flash.ipc」は IP の構成ファイルです。

#### 注記:

VHDL が設計の言語として選択されている場合、生成される最初の2つのファイル名のサフィックスは.vhd になります。

UG295-1.4.4J 34(34)

